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SYSTEM AND METHOD FOR REMOTE DOCUMENT RETRIEVAL 



5 TECHNICAL FIELD 

The present invention is generally related to the field of document retrieval 
and, more particularly, is related to a system and method for remote document 
retrieval via an electronic mail system. 



10 

BACKGROUND OF THE INVENTION 

Recent years have seen a proliferation of portable electronic devices such 
as personal digital assistants (PDA's), cellular telephones, and/or other portable 
electronic devices. For example, personal digital assistants are now available such 

15 as the HP Jornada manufactured by Hewlett-Packard Company based in Palo Alto, 
California, or the Blackberry™ manufactured by Research in Motion™ Limited 
based in Ontario, Canada as well as other brands. These mobile devices offer a 
range of capabilities, including mobile calendars, organizing capabilities, and 
electronic mail received and transmitted via a mobile pager network or other mobile 

20 networks, etc. 

Unfortunately, these devices are typically limited in their capabilities due to 
the fact that they are limited in their processing capacity and memory size. For 
example, many such devices cannot execute the many different applications that 
are available for the average personal computer. Specifically, such devices may 

25 not be able to implement word processors or other extensive applications. 

When it comes to activities such as printing, etc., such devices typically are 
unable to perform various tasks such as rendering documents in printer compatible 
form, etc. This fact can severely impact the usefulness of such devices. For 
example, a user may find themselves in the situation where they are standing in 

30 front of a printer with their personal digital assistant in hand and a document stored 
thereon that they wish to print. Unfortunately, in such a circumstance, the user may 
be prevented from printing a document with the printer due to the limited capability 
of the personal digital assistant. 
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In another situation, a user may find themselves visiting customers outside 
of their normal office where their own personal computer or company network 
reside. At such time, there may be a document that the user wishes to print out for 
his or her customers that is stored in a server or on the personal computer back at 
5 their office. Today's personal digital assistants lack the capability to interact with 
the network back at the office in order to obtain the document in electronic form. 
Also, assuming the user obtains the document, they are still faced with the difficulty 
of printing it out. 

In yet another situation, a user may have a laptop computer that has the 
10 computing capacity to perform the tasks necessary to print a document. However, 
the user may be in a location where they do not have access to their usual printer. 
In such a case, the user may be prevented from printing to any available printer 
because it is a different model that requires a rendering service or driver that is not 
stored on their laptop. 

15 

SUMMARY OF THE INVENTION 

In view of the foregoing, in one embodiment, the present invention provides 
for a document retrieval method that comprises the steps of receiving a request 

20 email message from a requesting device via a network, the request email message 
embodying a document request, automatically generating a response email 
message with at least one document attached thereto in response to the document 
request, and, automatically transmitting the response email message to a 
destination address on the network. 

25 In another embodiment, the present invention provides for a program 

embodied in a computer readable medium for retrieving a document. In this 
respect, the program comprises code that temporarily stores a request email 
message in a memory that was received from a requesting device via a network, 
the request email message embodying a document request. The program also 

30 comprises code that automatically generates a response email message with at 
least one document attached thereto in response to the document request, and, 
code that automatically transmits the response email message to a destination 
address on the network. 
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In still another embodiment, the present invention provides for a document 
retrieval system. In this respect, the document retrieval system includes a 
processor circuit having a processor and a memory. Stored in the memory and 
executable by the processor is a document retriever. The document retriever 
5 includes logic that temporarily stores a request email message in a memory that 
was received from a requesting device via a network, the request email message 
embodying a document request. The document retriever also includes logic that 
automatically generates a response email message with at least one document 
attached thereto in response to the document request, and, logic that automatically 
10 transmits the response email message to a destination address on the network. 

Other features and advantages of the present invention will become 
apparent to a person with ordinary skill in the art in view of the following drawings 
and detailed description. It is intended that all such additional features and 
advantages be included herein within the scope of the present invention. 

15 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS 

The invention can be understood with reference to the following drawings. 
The components in the drawings are not necessarily to scale. Also, in the 
20 drawings, like reference numerals designate corresponding parts throughout the 
several views. 

FIG. 1 depicts a block diagram that depicts a mobile print network according 
to an aspect of the present invention; 

FIG. 2 depicts a block diagram of a first mobile print configuration according 
25 to an aspect of the present invention; 

FIGS. 3A and 3B depict flow charts of an automated print agent employed at 
various points in the mobile print network of FIG. 1 ; 

FIGS. 4A-F depict drawings of various mobile print configurations according 
to aspects of the present invention; 
30 FIG. 5 depicts a block diagram of a document client in the mobile print 

network of FIG. 1 that includes a document retriever according to another aspect of 
the present invention; and 

FIGS. 6A and 6B depict a flow chart of the document retriever of FIG. 6. 
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DETAILED DESCRIPTION OF THE INVENTION 

With reference to FIG. 1, shown is a mobile print network 100 according to 
5 the present invention. The mobile print network 100 includes several components 
that interact with each other in various ways to accomplish the remote printing of a 
document as will be discussed. In the following discussion, first the physical make- 
up of the mobile print network 100 is provided followed by a description of the 
operation of the mobile print network 100. Thereafter, various components of the 
10 mobile print network 100 are described in greater detail with reference to figures 
that follow. 

To begin, the mobile print network 100 includes a network 103, a mobile 
network 106, and a local area network 109. The network 103 may be, for example, 
the Internet, a wide area network, or other network, or a combination of such 

15 networks. The mobile network 106 may comprise, for example, a pager network or 
cellular network that accommodates wireless transmission to mobile devices as is 
generally known by those with ordinary skill in the art. The local area network 109 
may comprise one of several technologies including, for example, a peer-to-peer 
architecture, a ring network, a star network, a token bus network, token passing 

20 technology, or token rings networks or other configurations. 

Coupled to the network 103 are a mobile print server 113 and a document 
client 116. The mobile print server 1 1 3 and the document client 116 may comprise, 
for example, a computer system or other such system as is generally known by 
those with ordinary skill in the art. The network 103 and the mobile network 106 

25 are coupled, for example, through a network gateway 119 that bridges data 
communication between the network 103 and the mobile network 106 as is 
generally known by those with ordinary skill in the art. 

The mobile print network 100 also includes a print site 123 that may be, for 
example, a particular company, institution, or other entity that employs the local 

30 area network 109. For purposes of facilitating the discussion herein, the print site 
123 is identified because one or more printers are located therein that a user may 
wish to use to print a particular document as will be discussed. In this respect, 
located at the print site 123 is an email server 126, a network gateway 128, a 

4 
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mobile print appliance 129, a print client 133, and a printer 136 all of which are 
coupled to the local area network 109. Since the printer 136 is a network printer, 
therefore, a queue server 139 is also included to control the flow of print jobs to the 
printer 136. Alternatively, a peer-to-peer approach may be employed to cause 
printing jobs to be sent to the printer 136. In such a case, the queue server 139 
may not be necessary as is generally known by those with ordinary skill in the art. 
Attached to the print client 133 is a local printer 143. Also, the mobile print network 
100 includes a mobile device 153 that is in wireless communication with the mobile 
network 106. The mobile device 153 may be, for example, the HP Jornada 
manufactured by Hewlett-Packard Company based in Palo Alto, California, or the 
Blackberry™ manufactured by Research in Motion™ Limited based in Ontario, 
Canada as well as other devices. 

The network gateway 128 may be employed to effect data communication 
between devices coupled to the local area network 109 and devices coupled to the 
networks 103 and 106. In this respect, the network gateway 128 may employ the 
Transmission Control Protocol/Internet Protocol (TCP/IP), Hypertext Transfer 
Protocol (HTTP), or other suitable technologies as is generally known by those with 
ordinary skill in the art. 

Many of the various devices that make up the mobile print network 100 
include various components and/or systems that may be implemented in terms of 
software, hardware, or a combination of software and hardware. Also, many of 
these components may be located in different ones of the devices in the mobile 
print network 100, thereby providing significant flexibility in the installation and 
operation as will be discussed. For instance, the mobile print server 113 may 
include an automated print agent 166, a rendering application 169 and a 
communications interface 173. In this respect, the mobile print server 113 may 
comprise, for example, a computer system or other like device. Note, however, that 
the automated print agent 166 and the rendering application 169 may or may not 
reside on the mobile print server 113 as will be discussed. 

The document client 116 includes an email system 183 with an associated 
email alias 184 that acts as the destination address of the email system 183 on the 
network 103. The document client 116 also includes a document retriever 186 that 
also may include a retriever alias 187 that similarly acts as the destination address 



HP Docket No. 10011123-1 

of the email system 183 on the network 103. One or more documents 189 or other 
files are stored on the document client 1 16. The document client 116 may also 
comprise a computer system or other like device. 

The email server 126 includes a gateway 193 that routes email messages to 
5 the various devices on the local area network 109. The email server 126 may also 
include the automated print agent 166 and the rendering application 169. In a 
similar manner the automated print agent 166 may be located on the mobile print 
appliance 129, the printer 136, or the print client 133. Likewise, the rendering 
application 169 may be located in the mobile print appliance 129 or the print client 

10 133 as shown. A print queue 196 is located on the queue server 139. In various 
embodiments, the communications interface 173 is located on the printer 136 and 
on the mobile print server 113. An electronic mail (email) system 183 is located on 
both the print client 133 and the mobile device 153. As contemplated herein, email 
refers to data information exchange using the Simple Mail Transfer Protocol 

15 (SMTP) or like protocol. 

Associated with each of the printers 136 and 143 are printer aliases 199a 
and 199b, respectively. Each of the printer aliases 199a and 199b is a unique 
address on the networks 103, 106, and 109 that identifies the respective printers 
136 and 143. In this regard, the aliases 199a and 199b may be, for example, email 

20 addresses, or addresses employed with some other information transport system 
employed on the networks 103, 106, and 109. Finally, the mobile device 153 
includes a document or multiple documents 203 that are stored thereon. Note that 
in associating each of the printer aliases 199a and 199b with the printers 136 and 
143, respectively, the printer aliases 199a are not necessarily maintained within the 

25 printers 136 and 143. Specifically, the printer aliases 199a and 199b may be 

stored in the email server 126, the automated print agent 166, or other system or 
device, etc., as can be appreciated by one with ordinary skill in the art. 

Next a general explanation of the operation of the mobile print network 100 
is provided in the context of several scenarios in which the mobile print network 100 

30 is employed to print a document and perform other tasks as desired by a particular 
user. In a first scenario, assume that a user who carries the mobile device 153 is 
visiting the print site 123 that happens to be one of the user's customers, etc. Also 
assume, for example, that the user is embroiled in negotiations to accomplish some 

6 
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business task as is typical. Stored on the mobile device 153 is a document 203 
that the user wishes to print out to provide copies to the customer during the course 
of the negotiations or other transaction. 

At the print site 123, the user may have several choices of printers, including 
5 printers 136 and 143 and other printers linked to the local area network 109, that 
they may use to print the document 203. Assume that the user chooses to print the 
document 203 on the printer 136 that is coupled directly to the local area network 
109. According to an aspect of the present invention, the user may walk up to the 
printer 136 and identify the particular printer alias 199a that is assigned thereto. 
10 According to one aspect of the present invention, the printer alias 199a is printed in 
a label form that is attached to the printer 136, thereby associating the alias with 
the printer 136. 

Alternatively, the printer 136 and the mobile device 153 may each include an 
infrared (IR) port with the capability of communicating via an IR signal protocol as 

15 are generally known by those skilled in the art. Provided both the printer 136 and 
the mobile device 153 have such capability, then a communications protocol may 
be implemented between both devices to communicate the printer alias 199a from 
the printer 136 to the mobile device 153 via an IR link. 

Once the user knows the printer alias 199a associated with the printer 136, 

20 the user then creates an email message with the email system 183 in the mobile 
device 153 and attaches the document 203 to be printed to the email message. 
The user then enters the printer alias 199a as the destination address for the email 
message and then transmits the email message to the printer 136. The email 
message with the attached document 203 then is transmitted from the mobile 

25 device 153 in a wireless connection to the mobile network 106. Upon detecting the 
destination address of the email message, the mobile network 106 then provides 
the email message to the network 103 through the network gateway 119. The 
network 103 then routes the same email message to the email server 126, and the 
gateway 193 in the email server 126 routes the email message to the automated 

30 print agent 166 through the local area network 109. 

Note that the automated print agent 166 may reside in any one of the mobile 
print appliance 129, the email server 126, the printer 136, the network gateway 
128, the printer 136, or other devices that are in data communication with the 
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mobile device 153. Alternatively, the gateway 193 may temporarily store the email 
message and will transmit the same to the automated print agent 166, wherever it 
is located, when polled by the automated print agent 166 in a "pull" relationship as 
is generally known by those with ordinary skill in the art. Alternatively, the printer 
5 alias 199a may route the email message to the automated print agent 166 that is 
located on the mobile print server 113. Regardless of where the automated print 
agent 166 is located, in all cases it acts as a network destination for the email 
message with the attached document 209 that was addressed to the printer alias 
199a. 

10 Upon receiving the email message with the attached document 203, the 

automated print agent 166 orchestrates the printing of the document 203 on the 
printer 136. In doing so, the automated print agent 166 transmits the document 
203 to the rendering application 169, wherever it is located, in order to have the 
document 203 rendered in a printer ready format. The rendering application 169 

15 may be located in the email server 126, the mobile print appliance 129, the mobile 
print server 1 13, or the network gateway 128 as shown as well as other devices 
that are in data communication with the automated print agent 166. The printer 
ready format may be, for example, printer control language (PCL) or PostScript, 
such printer ready formats being generally known by those with ordinary skill in the 

20 art. 

When the document 203 is rendered in the appropriate printer control 
language by the rendering application 169, it transmits the rendered document 
back to the automated print agent 166. All communication between the automated 
print agent 166 and the rendering application 169 may be accomplished using a 

25 transport mechanism such as email, hypertext transfer protocol (HTTP), or other 
communications protocol, etc., between the rendering application 169 and the 
automated print agent 166. When the automated print agent 166 receives the 
rendered document 203 back from the rendering application 1 69, the automated 
print agent 166 then applies the document to the print queue 196 in the queue 

30 server 139 that ultimately causes the document 203 to be printed on the printer 
136. In those cases in which a queue server 139 is not used, the document 203 is 
sent directly to the printer 136 as can be appreciated by one with ordinary skill in 
the art. The fact that the automated print agent 166 and the rendering application 

8 
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169 can be located in the various different devices in the mobile print network 100 
provides flexibility in the manner in which a mobile print capability can be 
implemented as can be appreciated by one with ordinary skill in the art. 

In another scenario, a user of the mobile device 153 wishes to print the 
5 document 203 on the printer 143 that is locally attached to the print client 133 that 
may be, for example, a computer system or other like device, etc. Note that the 
print client 133 may also be coupled to the network 103 or to some other network 
other than the local area network 109 as can be appreciated by those with ordinary 
skill in the art. Assuming the user wishes to print to the printer 143, the user 

10 creates an email message that is addressed using the printer alias 199b and 
attaches one or more documents 203 thereto to be printed. The user then 
transmits the email message with the attached documents 203 to the email server 
126. The gateway 193 then routes the email message to the print client 133 that is 
ultimately received by the automated print agent 166. Alternatively, the email 

1 5 message may be received by the email system 1 83 that interfaces with the 

automated print agent 166 and forwards all such email messages to the automated 
print agent 166. 

Ultimately, the automated print agent 166 receives the email message with 
the attached documents 203 and orchestrates the printing of the documents 203. 

20 Specifically, the automated print agent 166 detaches the documents 203 from the 
email message and applies them to the rendering application 169 on the print client 
133 for rendering into the printer control language that is associated with the printer 
143. Once the documents 203 are rendered in the printer control language, then 
the automated print agent 166 applies the documents 203 to the printer 143. In 

25 addition, note that the automated print agent 166 and the rendering application 169 
may reside in devices other than the print client 133. However, in such case, a 
proper interface should be located in the print client 133 to interface with the 
automated print agent 166 and to hand off all print jobs received from the 
automated print agent 166 to the printer 143. 

30 In another scenario, the document retrieval features of the mobile print 

network 100 are described. Assume that a user of the mobile device 153 finds 
themselves at the print site 123 without the document 189 that they wanted to print 
for a particular customer. Specifically, the document 189 is stored on the print 

9 
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client 116 that may be, for example, the user's computer system or like device 
located back at their office, eto. Since the document 189 is remotely stored in the 
document client 116, the user does not have access to the document 189 in order 
to print it at the print site 123. However, the present invention provides the user of 
the mobile device 153 with remote access to the document 189 that is stored on 
the document client 116. Specifically, the user remotely accesses the document 
189 by generating a request for the document in the form of an email message 
using the email system 183 on the mobile device 153 that is transmitted to the 
document client 116. 

Thus, the email message is a "request" email message that embodies a 
document request for the document 189 stored on the document client 116. The 
request email message conforms to a predefined format that is understood by the 
document retriever 186. In this respect, a user interface may be employed in the 
mobile device 153 to generate the request to ensure that the request email 
message is generated in the proper format. The destination address included in 
the request email message may be the email alias 184 or the retriever alias 187 
that directs the email message to either the email system 183 or the document 
retriever 186, respectively. Ultimately, the request email message is to be sent to 
the document retriever 1 86. If it is sent to the email system 183, then the document 
retriever 186 is appropriately configured to interface with the email system 183 to 
obtain the request email message therefrom. 

When the document retriever 186 ultimately receives the request email 
message from the mobile device 153, it generates a reply email message in 
response thereto. The document retriever 186 attaches the requested document 
189 to the reply email message and then automatically transmits the reply email 
message with the attached document 189 back to the mobile device 153. In this 
manner, the user of the mobile device 153 may obtain the document 189 from the 
document client 116 using the email system 183 as a transport mechanism. 
Alternatively, a data communications protocol other than the email system 183 may 
be employed as the transport mechanism. However, use of an email system as a 
transport mechanism provides a distinct advantage in that existing email 
infrastructure may be employed. 
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Note that the request email message would include the directory location 
and file name of the document 189 that is to be retrieved by the document retriever 
186. This information is embodied in the request email message according to a 
predetermined format. However, in those circumstances where the user of a 
5 mobile device 1 53 cannot remember the directory and/or the file name of the 
document 189, the user may transmit a directory request email message to the 
document retriever 186. In response, the document retriever 186 generates a 
directory reply email message that includes a directory file listing of the files stored 
within the document client 116. The directory file listing is transmitted back to the 

10 mobile device 153 in a directory response email message to provide the user with a 
detailed list of the file names of all the documents 189 stored in the document client 
116 and the directory under which each of the documents 189 is stored. 

In addition, if the user of the mobile device 153 wishes to print the document 
189 retrieved from the document client 1 16 on the printer 136, then the user may 

15 specify a destination address for the document 189 in the request email message 
transmitted to the document retriever 186. Specifically, in order to print the 
document 189 on the printer 136, the user would include the printer alias 199a in 
the request email message as the destination address for the document 189. Upon 
receiving such a request email message, the document retriever 186 then 

20 generates the reply email message addressed to the printer alias 199a with the 
document 189 attached thereto. The reply email message is then transmitted to 
the corresponding automated print agent 166 designated to receive the emails 
addressed to the printer alias 186 wherever it resides in the local area network 109 
to print the document 189 on the printer 136 as was described previously. 

25 With reference to FIG. 2, shown is a block diagram of the mobile print 

appliance 129 that is coupled to the printer 136 through the local area network 109 
to provide a further illustration of one of the scenarios described above. As shown, 
the mobile print appliance 129 includes a processor 233 and a memory 236, both of 
which are coupled to a local interface 239. The local interface 239 may be, for 

30 example, a data bus with an accompanying control/address bus as is understood 
by those with ordinary skill in the art. Stored on the memory 236 and executable by 
the processor 233 are an operating system 243, the automated print agent 166, 
and the rendering application 169. The mobile print appliance 129 also includes a 

11 
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local area network interface 246 that links the local interface 239 to the local area 
network 109. In this respect, the local area network interface 246 may be, for 
example, a network card or other such device as is generally known by those with 
ordinary skill in the art. 

The printer 136 also includes a processor circuit having a processor 253 and 
a memory 256, both of which are coupled to a local interface 259. The local 
interface 259 may be a data bus with an accompanying control/address bus as is 
generally known by those with ordinary skill in the art. Stored on the memory 256 
and executable by the processor 253 are an operating system 263 and a printer 
control system 266. The printer control system 266 generally provides for the 
operation of the printer 136 itself as is generally known by those with ordinary skill 
in the art. In this respect, the printer 136 includes various printer components 269 
such as motors and mechanical paper path components as well as image creation 
components that generally provide for print operation. The printer 136 also 
includes a local area network interface 273 that couples the local interface 259 to 
the local area network 109 as shown. In this respect, the local area network 
interface 273 may be a network card or other such device as is generally known by 
those with ordinary skill in the art. 

FIG. 2 illustrates one embodiment of the mobile print appliance 129 and the 
printer 136 with respect to the fact that both the mobile print appliance 129 and the 
printer 136 employ a processor circuit as described that implements the various 
components stored on the memories 236 and 256. With reference back to FIG. 1, 
several other components of the mobile print network 100 may also be 
implemented using a processor circuit in a similar manner with as shown with 
respect to the mobile print appliance 129 and the printer 136 in FIG. 2. In this 
respect, the mobile print server 113, document client 116, email server 126, 
network gateway 128, the print client 133, the queue server 139, the printer 136, 
the printer 143, and the mobile device 153 may all employ processor circuits in a 
similar manner to the mobile print appliance 129 and the printer 136 as depicted in 
FIG. 2. All of these devices may be, for example, a computer system or other 
system as is generally known by those with ordinary skill in the art. Note that while 
the mobile device 153 may include a processor circuit, such a circuit may be limited 
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in its processing capacity as compared to the processing capacity of other 
components in the mobile print network 100. 

The mobile print appliance 129, the mobile print server 113, document client 
116, email server 126, network gateway 128, the print client 133, the queue server 
139, the printer 136, the printer 143, and the mobile device 153 may all include 
various peripheral devices. In particular, peripheral devices may include, for 
example, a keypad, touch pad, touch screen, microphone, scanner, mouse, 
joystick, or one or more push buttons, etc. The peripheral devices may also include 
display devices, indicator lights, speakers, printers, etc. Specific display devices 
may be, for example, cathode ray tubes (CRT), liquid crystal display screens, gas 
plasma-based flat panel displays, or other types of display devices, etc. 

In addition, each of the memories 236 and 256 may include both volatile and 
nonvolatile memory components. Volatile components are those that do not retain 
data values upon loss of power. Nonvolatile components are those that retain data 
upon a loss of power. Thus, each of the memories 236 and 256 may comprise, for 
example, random access memory (RAM), read-only memory (ROM), hard disk 
drives, floppy disks accessed via an associated floppy disk drive, compact discs 
accessed via a compact disc drive, magnetic tapes accessed via an appropriate 
tape drive, and/or other memory components, or a combination of any two or more 
of these memory components. In addition, the RAM may comprise, for example, 
static random access memory (SRAM), dynamic random access memory (DRAM), 
or magnetic random access memory (MRAM) and other such devices. The ROM 
may comprise, for example, a programmable read-only memory (PROM), an 
erasable programmable read-only memory (EPROM), an electrically erasable 
programmable read-only memory (EEPROM), or other such of memory device. 

Also, each of the processors 233 and 253 may represent multiple processors 
and each of the memories 236 and 256 may represent multiple memories that 
operate in parallel processing circuits, respectively. In such a case, each of the 
local interfaces 239 and 259 may be an appropriate network that facilitates 
communication between any two of the multiple processors, between any 
processor and any of the memories, or between any two of the memories, etc. The 
processors 233 and 253 may be electrical or optical in nature. 
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The operating systems 243 and 263 are executed to control the allocation 
and usage of hardware resources in the mobile print appliance 129 and the printer 
136, respectively. Specifically, the operating systems 243 and 263 control the 
allocation and usage of the memories 236 and 256, processing time, and the 
peripheral devices as well as performing other functionality. In this manner, the 
operating systems 243 and 263 serve as the foundation on which applications 
depend as is generally known by those with ordinary skill in the art. 

Referring then to FIGS. 3A and 3B, shown is a flow chart of the automated 
print agent 166 that may reside within the various devices of the mobile print 
network 100 (FIG. 1) as discussed previously. Alternatively, the flow chart of FIGS. 
3A and 3B may be viewed as depicting steps in a corresponding method. As was 
previously described, the automated print agent 166 is executed in order to 
orchestrate the printing of a document attached to an email message that was 
received by the automated print agent 166. 

With specific reference to FIG. 3A, beginning with box 303, the automated 
print agent 166 determines whether an email message with an attached document 
to be printed has been received. The specific detecting of an email message with 
an attached document to be printed may be accomplished in several different ways. 
For example, the automated print agent 166 may be designated as the network 
destination for a particular printer alias 199a or 199b. In such case, the 
corresponding email message is applied directly to the automated print agent 166 
by the gateway 193 (FIG. 1) in the email server 126 (FIG. 1). The automated print 
agent 166 may also pull such email messages from the gateway 193 by 
implementing a "pull" configuration as is generally known by those with ordinary 
skill in the art. 

In another alternative, the automated print agent 166 may interface with an 
email system 183 (FIG. 1) to obtain the email message that was originally received 
by the email system 183. However the automated print agent 166 receives the 
email message with the attached document to be printed, upon receiving such an 
email message the automated print agent 166 proceeds to box 306 to perform 
various filtering tasks. The filtering tasks may comprise, for example, a blocking 
task that restricts access to the corresponding printer to select users in cases 
where various organizations wish to limit the ability of individuals to print on a 
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particular printer. This may be done, for example, by examining the "from" field in a 
particular email message to determine if the message was sent by an authorized 
user. Also, other security access technology may be employed to restrict the 
access to specific users such as, for example, employing security codes or other 
5 such approaches. In addition, the filtering tasks may include scanning for viruses in 
the attachment and in the email, as well as performing authentication routines to 
ensure that the user who sent the email message with the attached document is 
the person that he or she represents himself or herself to be. To accomplish the 
virus scanning and authentication tasks, various technologies that are generally 
10 available on the market may be employed as is generally known by those with 
ordinary skill in the art. 

After the filtering tasks are completed in box 306, the automated print agent 
166 proceeds to box 309 to determine whether any decryption is to be performed 
on the email message with the attached document. If the email message and 
1 5 attachments were encrypted, then the automated print agent 1 66 proceeds to box 
313 to execute an appropriate decryption system as is generally known by those 
with ordinary skill in the art. Thereafter, the automated print agent 166 proceeds to 
box 316. Also, if it is discovered that there is no decryption to be performed in box 
309, then the automated print agent 166 proceeds to box 316. 
20 In box 316, the automated print agent 166 breaks down the email message 

by separating the one or more attachments from the email message that was 
received. Note that this may be accomplished employing various components of 
the JavaX.mail libraries that are commercially available. The JavaX.mail libraries 
are created and marketed by Sun Microsystems, Inc., of Palo Alto, California. 
25 Thereafter, the automated print agent 1 66 proceeds to box 31 9 in which the 

printer associated with the destination email address of the email message is 
identified. Specifically, the destination email address will be one of the printer 
aliases 199a (FIG. 1) or 199b (FIG. 1) as discussed previously. An association 
may be drawn between the printer 136 or 143 and the respective printer alias 199a 
30 or 199b by consulting a predefined lookup table that is stored as a portion of the 
automated print agent 166. The lookup table may be created by network 
administrators in setting up the mobile print network 100 as can be appreciated by 
those with ordinary skill in the art. The automated print agent 166 then proceeds to 
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box 323 in which a loop is designated to process and print the email message and 
the one or more attachments. In this respect, the email message and the 
attachments are separated into separate "documents" for printing. In this regard, a 
document is defined as either the email itself or as one of the attachments that is to 
be printed separately on the respective printer 136 or 143. In designating a loop to 
process each one of these documents in box 323, the first document, usually the 
email message, is designated for processing. 

Thereafter, in box 326 a print job is created for the current document that 
has been identified for processing. The printer 136 or 143 that is to be employed to 
print the document is associated with the print job. Also any requested print 
options that are included in the email message are also associated with the print 
job in order to affect proper rendering of the document. Specifically, the particular 
printer should be provided to the rendering application 169 (FIG. 1) in order to 
render the document in the format that is compatible with a particular printer 136, 
143. Also if there are any print options that have been specified by the user of the 
mobile device 153 that are to be adhered to in rendering the document, such 
information needs to be included in the print job accordingly. 

With reference to FIG. 3B, the automated print agent 166 then proceeds to 
box 329 in which a rendering application 169 is identified to render the print job in a 
printer ready format. In order to make this determination, the automated print agent 
166 may include a rendering lookup table that provides the ability to determine the 
name and location of a specific rendering application 169 in the case that several 
different rendering applications 169 exist from which to choose. Alternatively, a 
single rendering application 169 may be employed. When the proper rendering 
application 169 is identified, then in box 333 the print job is applied to the 
appropriate rendering application 169 to be rendered in the printer ready format. 
Such a printer ready format may include, for example, printer control language 
(PCL) or PostScript. Note there may be other printer formats that are rendered by 
a particular rendering application 169 as can be appreciated by one with ordinary 
skill in the art. 

In box 336, the automated print agent waits for the return of the rendered 
print job from the rendering application 169. Thereafter, in box 339 it is determined 
whether there were any printing errors that occurred during the rendering operation. 
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Such may be the case, for example, if the rendering application was incapable of 
fulfilling all of the requested print options or if the rendering application 169 was 
unable to perform the rendering function at all. If there is an error in box 339, then 
the automated print agent 166 proceeds to box 343 in which an email message is 
generated that details the error related to the current print job and transmits the 
email message to the sender. Note that the destination of the error email is easily 
determined by obtaining the "from" address off of the email message that was 
received from the user of the mobile device 1 53. 

On the other hand, assuming there is no error detected in box 339, then the 
automated print agent 166 proceeds to box 346 in which an email message is 
generated that informs the user of the mobile device 153 that the current print job 
was printed successfully. Note that this notification is not entirely necessary and it 
is possible to skip this task. This email message is transmitted to the user of the 
mobile device 153 in a similar manner as the error email is transmitted in box 343. 
After box 346, the automated print agent 166 proceeds to box 349 in which the 
current print job is queued up for printing in the associated printer identified in box 
319 (FIG. 3A). Alternatively, in the case that a printing queue is not employed, then 
the print job may be applied directly to the printer itself. 

With reference back to box 343, once the error email is transmitted to the 
user of a mobile device 153 then the automated print agent 166 proceeds to box 
346. In box 346 it is determined whether the particular error detected in box 339 
involves a complete failure to render the document thereby resulting in a failure to 
print the particular document. If such is the case then the automated print agent 
166 proceeds to box 353. Otherwise, the automated print agent 166 moves to box 
349. If the automated print agent 166 proceeds from box 346 to box 349, then 
generally the print error is assumed to be minor such that the document was 
rendered by the rendering application 169 using default parameters. These default 
parameters may differ from the print options specified by the user and associated 
with the print job in box 326. Thus, the ultimate printing of a document may be in a 
format that differs from that desired by the user. However, the user may determine 
what action is to be taken upon reception of the email informing the user of the fact 
that a print error occurred at the mobile device 153. Also, the user can also 



17 



HP Docket No. 10011123-1 



determine what action to take upon viewing the document as it was printed by the 
respective printer 136 or 143. 

Once the print job has been queued up for printing or otherwise applied to a 
printer 136 or 143, or assuming that a print failure has been detected in box 346, 

5 the automated print agent 166 proceeds to box 353. In box 353 it is determined 
whether the last document has been processed in the current loop designated in 
box 323. If not then the automated print agent 166 moves to box 356 in which the 
next document is designated for processing. Thereafter, the automated print agent 
166 reverts to box 326 to repeat the process for the next document. Otherwise, the 

1 0 automated print agent 1 66 then reverts back to box 303 to await the receipt of the 
next email message with attachments to be printed. 

With reference next to FIGS. 4A-4E, shown are several different mobile print 
configurations that illustrate the various devices in which the auto print agent 166 
and the rendering application 169 may be located to provide various examples of 

1 5 the implementation of the mobile print network 1 00 (FIG. 1 ) according to the 
present invention. With reference specifically to FIG. 4A, shown is a first mobile 
print configuration 370 that includes the email server 126, the mobile print 
appliance 129, and the printer 136, all of which are coupled to the local area 
network 109 as described with reference to FIG. 1. The auto print agent 166 and 

20 the rendering application 169 are located on the mobile print appliance 129. In this 
respect, the mobile print appliance 129 is easily fit within the local area network 109 
without disrupting or changing any existing devices coupled to the local area 
network 109. Specifically, the email server 126 that includes the gateway 193 and 
the printer 136 remain unchanged. 

25 Referring to FIG. 4B, shown is a second mobile print configuration 373 in 

which the rendering application 169 is located on the email server 126 and the auto 
print agent 166 is located on the printer 136. Such may be the case when the 
printer 136 has the processing power to execute the auto print agent 166 in 
addition to its usual printing operation. In sending a print job to the rendering 

30 application 169, the auto print agent 166 employs the protocol used by the local 
area network 109. Note however that the second mobile print configuration 373 
does include a downside. In particular, the rendering application 169 may bog 
down the operation of the email server 126 that might inhibit the speed of operation 

18 



HP Docket No. 10011123-1 



of the gateway 193 in distributing email messages to other devices on the local 
area network 109. However, the second mobile print configuration 373 includes the 
advantage that no additional devices need to be coupled to the local area network 
109. This may be beneficial where there is little room for expansion on a specific 
local area network 109. 

With reference to FIG. 4C, shown is a third mobile print configuration 376 in 
which the auto print agent 166 and the rendering application 169 are both located 
on the email server 126. The third mobile print configuration 376 includes the same 
benefit of the second mobile print configuration 373 (FIG. 4B) in that no new 
devices are coupled to the local area network 109 as is the case with the first 
mobile print configuration 370 (FIG. 4A). However, due to the fact that the auto 
print agent 166 and the rendering application 169 both reside on the email server 
126, it is possible that the speed of operation of the gateway 193 will be 
significantly affected. This is because the additional processing requirements of the 
auto print agent 166 and the rendering application 169 will consume processing 
power that normally would have been devoted to the gateway 193. 

With respect to FIG. 4D, shown is a fourth mobile print configuration 379 that 
employs the email server 126, the mobile print appliance 129, and the printer 136, 
all of which are coupled to the local area network 109 as described with FIG. 1. 
Note however, that the rendering application 169 is stored and executed in the 
mobile print appliance 129 and the auto print agent 166 is stored and executed in 
the printer 136. This assumes that the printer 136 includes the extra processing 
capacity to store and execute the auto print agent 166. 

With reference to FIG. 4E, shown is a fifth mobile print configuration 383 in 
which the auto print agent 166 resides on the printer 136 and the rendering 
application 166 resides on the mobile print server 113. In this respect, the auto 
print agent 166 requests the rendering of a particular document from the rendering 
application 169 by transmitting a rendering request to the mobile print server 113. 
In order to facilitate communication between the printer 136 and the mobile print 
server 113, the communications interface 173 is provided in both the mobile print 
server 113 and the printer 136. In this respect, the communications interface 173 
may entail the use of various protocols including, for example, the simple object 
access protocol (SOAP) 1.1 that is promulgated by the W3C organization as is 
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generally known by those with ordinary skill in the art. In this manner, SOAP may 
be employed in combination with the hypertext transfer protocol (HTTP) as is 
generally known by those with ordinary skill in the art. Note that the fifth mobile 
print configuration 383 assumes that the printer 136 includes the processing 
5 capacity to store and execute the auto print agent 166 and the communications 
interface 173. The fifth mobile print configuration 383 provides an advantage in 
that it does not require a separate mobile print appliance 129 to be attached to the 
local area network 109 and it will not slow down or otherwise inhibit the operation of 
the email server 126. 

10 With reference to FIG. 4F, shown is a sixth mobile print configuration 386 

according to another aspect of the present invention. In the sixth mobile print 
configuration 386, the auto print agent 166 and the rendering application 169 are 
located in the mobile print server 113 according to an aspect of the present 
invention. In this respect, when the printer alias 199a is employed as the 

15 destination address of an email message with an attachment to be printed, the 
email message is directed to the auto print agent 166 on the mobile print server 
1 13 through the network 103. The auto print agent 166 performs its tasks on the 
mobile print server 113 and interfaces with the rendering application 169 as needed 
to render the document into the printer ready format. The documents to be printed 

20 are then transmitted to the printer 136 using the communications interface 173 that 
was described with respect to the fifth mobile print configuration 383 (FIG. 4E). 
This particular configuration provides significant advantages in that only the 
communications interface 173 need be included in the printer 136 in order that it 
can receive the document from the mobile print server 113. 

25 Referring next to FIG. 5, shown is the document client 116 according to 

another aspect of the present invention. As shown, the document client 116 
includes a processor circuit with a processor 403 and a memory 406, both of which 
are coupled to a local interface 409. The local interface 409 may be, for example, a 
data bus with an accompanying control/address bus as is generally known by those 

30 with ordinary skill in the art. The document client 116 also includes a network 

interface 413 that links the local interface 409 to the network 103. In this respect, 
the network interface 413 may comprise, for example, an appropriate modem or 
interface card as is generally known by those with ordinary skill in the art. In 
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addition, stored on the memory 406 and executable by the processor 403 are an 
operating system 416, the email system 183, the document retriever 186, and the 
document 189. 

The document client 116 may include one or more peripheral devices such 
as, for example, a keypad, touch pad, touch screen, microphone, scanner, mouse, 
joystick, or one or more push buttons, etc. The peripheral devices may also include 
display devices, indicator lights, speakers, printers, etc. Specific display devices 
may be, for example, cathode ray tubes (CRT), liquid crystal display screens, gas 
plasma-based flat panel displays, or other types of display devices, etc. 

The memory 406 may include both volatile and nonvolatile memory 
components. Volatile components are those that do not retain data values upon 
loss of power. Nonvolatile components are those that retain data upon a loss of 
power. Thus, the memory 406 may comprise, for example, random access 
memory (RAM), read-only memory (ROM), hard disk drives, floppy disks accessed 
via an associated floppy disk drive, compact discs accessed via a compact disc 
drive, magnetic tapes accessed via an appropriate tape drive, and/or other memory 
components, or a combination of any two or more of these memory components. 
In addition, the RAM may comprise, for example, static random access memory 
(SRAM), dynamic random access memory (DRAM), or magnetic random access 
memory (MRAM) and other such devices. The ROM may comprise, for example, a 
programmable read-only memory (PROM), an erasable programmable read-only 
memory (EPROM), an electrically erasable programmable read-only memory 
(EEPROM), or other such of memory device. 

In addition, the processor 403 may represent multiple processors and the 
memory 406 may represent multiple memories that operate in parallel. In such a 
case, the local interface 409 may be an appropriate network that facilitates 
communication between any two of the multiple processors, between any 
processor and any one of the memories, or between any two of the memories etc. 
The processor 403 may be electrical or optical in nature. 

The operating system 416 is executed to control the allocation and usage of 
hardware resources in the document client 116. Specifically, the operating system 
416 controls the allocation and usage of the memory 406, processing time, and the 
peripheral devices as well as performing other functionality. In this manner, the 
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operating system 416 serves as the foundation on which applications depend as is 
generally known by those with ordinary skill in the art. 

The document retriever 186 is implemented to provide a document 189 to 
the user in response to a request email message that was sent from a remote 
5 device such as, for example, the mobile device 153 (FIG. 1) or other device 
coupled either directly or indirectly with the network 103. 

Turning then to FIG. 6A, shown is a flow chart of the operation of the 
document retriever 186 according to an aspect of the present invention. 
Alternatively, the flow chart of FIG. 6A may be viewed as depicting steps in a 

10 method implemented in the document client 116 (FIG. 5). The document retriever 
186 is executed by the document client 116 to supply the document 189 (FIG. 5) to 
a remote device in response to a request email message as was previously 
described. Beginning with box 430, the document retriever 186 waits until it 
receives a request email message from a requesting device. Note that the request 

15 email message may be received by the email system 183 if addressed to the email 
alias 184 (FIG. 5) or it may be received directly by the document retriever 186 if 
addressed to the retriever alias 187. In any case, assuming that the document 
retriever 186 receives the request email message that embodies the document 
request for the document 189, the document retriever 186 proceeds to box 433. In 

20 box 433, the request is filtered in a similar manner to the filtering that is executed in 
box 306 (FIG. 3A) relative to the automated print agent 166. 

Thereafter, the document retriever 186 proceeds to box 436 in which it is 
determined whether the request email message is to be decrypted. If so, then the 
document retriever 186 proceeds to box 439 in which the appropriate decryption 

25 system is executed to decrypt the request email message accordingly. However, if 
no decryption is required in box 436, then the document retriever 186 proceeds to 
box 443. In box 443, the document retriever 1 86 determines whether the request 
email message is a request for a directory file listing of the one or more documents 
189 stored on the memory 406. If the request email message is such a request in 

30 box 443, then the document retriever 1 86 moves to connector T as shown. 

Otherwise, the document retriever 186 assumes that the request email message is 
an actual request for the document 189 and the document retriever 186 proceeds 
to box 446. 
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In box 446, the request email message is scrutinized to determine whether it 
is in the proper format such that the document retriever 186 recognizes the 
requested document, the directory location of that document in the document client 
1 1 6, and any other information pertinent to the retrieval of the document 1 89. If the 
request email message is not in a proper format, then the document retriever 186 
proceeds to box 449 in which an incorrect format message is generated and 
transmitted to the original sender of the request email message. The incorrect 
format message may actually be a reply email message that is automatically sent 
back to the originator of the request email message as is generally understood by 
those with ordinary skill in the art. Thereafter, the document retriever reverts back 
to box 430 to await the receipt of the next request email message. 

Assuming however that the request email message is properly formatted in 
box 446, then the document retriever 186 proceeds to box 453 in which the request 
email message is parsed by the document retriever 186 to identify the file name 
and location of the document 189 to be retrieved in the request pay load of the 
request email message. Thereafter, in box 456, the document retriever 186 
attempts to find the file that corresponds to the document 189 in the memory 406 
(FIG. 5) of the document client 1 1 6. 

If the proper file can not be found in the memory 406, then the document 
retriever 186 proceeds to box 459 in which a reply email message is generated and 
transmitted to the sender of the request email message that indicates that the file 
can not be found. Thereafter, the document retriever 186 reverts back to box 430 
in order to await the receipt of the next request email message. 

However, assuming that the proper file is found in the memory 406, then the 
document retriever 186 proceeds to box 463 in which it is determined whether the 
document is to be forwarded to a third party address separate from the address of 
the sender. If the document is to be forwarded, then the document retriever 186 
moves to box 466. Otherwise, the document retriever 186 proceeds to box 469. In 
box 466, a forwarded email message is generated in the memory 406 for transport 
to the ultimate destination address that was specified in the request email 
message. The document retriever 186 determines that a forwarding email is to be 
created, as opposed to a reply email, by identifying whether a forwarding email 
address is indicated in the request email message from the original sender. After 
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the forward email message is generated in box 466, the document retriever 186 
proceeds to box 473. 

Assuming, that the document retriever 186 proceeds to box 469, then a reply 
email message is generated in the memory 406 for transmission to the sender. 
5 Thereafter, in box 473 the requested document 189 stored in the memory 406 is 
attached to the reply email message to the sender. Then, the document retriever 
186 proceeds to box 476 in which either the forward or reply email message is sent 
to the ultimate network destination in the form of an email transmission. Thereafter, 
the document retriever 1 86 reverts back to box 430 to await the receipt of another 

10 request email message. 

Referring next to FIG. 6B, shown is a flow chart that shows the continuation 
of the document retriever 186 or method from FIG. 6A. Assuming that the request 
email message received from the sending device is a request for a directory file 
listing in box 443, then the document retriever 186 proceeds to box 483 in which it 

1 5 is determined whether the directory request email message is properly formatted 
according to the standards employed by the document retriever 186. If not, then 
the document retriever 186 proceeds to box 486 in which an incorrect format 
message is generated and transmitted via email to the sending device. Thereafter, 
the document retriever reverts back to box 430 (FIG. 6A) to await the arrival of the 

20 next request email message. Assuming however that the directory request email 
message is in the proper format in box 483, then the document retriever 186 
proceeds to box 489 in which the directory file listing of the document client 1 16 is 
looked up to be provided to the requester. 

Note that this lookup function may be restricted to specific directories in the 

25 document client 1 1 6 or it may entail ail of the directories of the document client 1 1 6 
in the memory 406. After the directory information is obtained in box 489, the 
document retriever 186 proceeds to box 493 in which it is determined whether the 
directory file listing is to be forwarded to a third party address or to be transmitted 
back to the sender in the form of a reply email. The reply email approach is used, 

30 for example, when a user wishes to view the directory on the device such as the 
mobile device 153 (FIG. 1) from which they sent the request. However, the user 
may wish to have the directory printed out on the printer 136 or 143 so they can 
view the directory in paper hard copy. The determination as to whether or not the 
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directory is to be forwarded to a third party address or to be sent in a reply email 
back to the sender is made by examining the directory request to identify whether a 
forwarding address is indicated therein. If a forwarding address is not present, then 
the "from" address of the directory email is employed to send the directory 
5 information in a reply email. 

Thus, in box 493, assuming that the directory file listing is to be forwarded to 
a third party address then the document retriever 186 proceeds to box 496 in which 
the forward email is assembled in the memory 406. On the other hand, if the 
directory file listing is to be sent to the original sender by way of a reply, then the 

10 document retriever 186 proceeds to box 499 in which the reply email is assembled 
and stored in the memory 406. From boxes 496 and 499, the document retriever 
186 proceeds to box 503 in which the directory file listing is included in the newly 
created email message in the memory 406. Then, in box 506, the directory 
response email message is transmitted to the network destination indicated by the 

15 address associated therewith. Thereafter, the document retriever 186 then reverts 
back to box 430 to await the receipt of the next request email message. 

Although the automated print agent 166 and the document retriever 186 of 
the present invention are embodied in software or code executed by general 
purpose hardware as discussed above, as an alternative the automated print agent 

20 166 and the document retriever 186 may also be embodied in dedicated hardware 
or a combination of software/general purpose hardware and dedicated hardware. If 
embodied in dedicated hardware, the automated print agent 166 and the document 
retriever 186 can be implemented as a circuit or state machine that employs any 
one of or a combination of a number of technologies. These technologies may 

25 include, but are not limited to, discrete logic circuits having logic gates for 
implementing various logic functions upon an application of one or more data 
signals, application specific integrated circuits having appropriate logic gates, 
programmable gate arrays (PGA), field programmable gate arrays (FPGA), or other 
components, etc. Such technologies are generally well known by those skilled in 

30 the art and, consequently, are not described in detail herein. 

The flow charts of FIGS. 3A, 3B, 6A, and 6B show the architecture, 
functionality, and operation of an implementation of the automated print agent 166 
and the document retriever 186. If embodied in software, each block may 

25 



HP Docket No. 10011123-1 



represent a module, segment, or portion of code that comprises program 
instructions to implement the specified logical function(s). The program instructions 
may be embodied in the form of source code that comprises human-readable 
statements written in a programming language or machine code that comprises 
numerical instructions recognizable by a suitable execution system such as a 
processor in a computer system or other system. The machine code may be 
converted from the source code, etc. If embodied in hardware, each block may 
represent a circuit or a number of interconnected circuits to implement the specified 
logical function(s). 

Although the flow charts of FIGS. 3A, 3B, 6A, and 6B show a specific order 
of execution, it is understood that the order of execution may differ from that which 
is depicted. For example, the order of execution of two or more blocks may be 
scrambled relative to the order shown. Also, two or more blocks shown in 
succession in FIGS. 3A, 3B, 6A, or 6B may be executed concurrently or with partial 
concurrence. In addition, any number of counters, state variables, warning 
semaphores, or messages might be added to the logical flow described herein, for 
purposes of enhanced usability, accounting, performance measurement, or 
providing troubleshooting aids, etc. It is understood that all such variations are 
within the scope of the present invention. Also, the flow charts of FIGS. 3A, 3B, 6A, 
and 6B are relatively self-explanatory and are understood by those with ordinary 
skill in the art to the extent that software and/or hardware can be created by one 
with ordinary skill in the art to carry out the various logical functions as described 
herein. 

Also, where the automated print agent 166 and the document retriever 186 
comprise software or code, it can be embodied in any computer-readable medium 
for use by or in connection with an instruction execution system such as, for 
example, a processor in a computer system or other system. In this sense, the 
logic may comprise, for example, statements including instructions and declarations 
that can be fetched from the computer-readable medium and executed by the 
instruction execution system. In the context of the present invention, a "computer- 
readable medium" can be any medium that can contain, store, or maintain the 
automated print agent 166 and the document retriever 186 for use by or in 
connection with the instruction execution system. The computer readable medium 
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can comprise any one of many physical media such as, for example, electronic, 
magnetic, optical, electromagnetic, infrared, or semiconductor media. More specific 
examples of a suitable computer-readable medium would include, but are not 
limited to, magnetic tapes, magnetic floppy diskettes, magnetic hard drives, or 

5 compact discs. Also, the computer-readable medium may be a random access 
memory (RAM) including, for example, static random access memory (SRAM) and 
dynamic random access memory (DRAM), or magnetic random access memory 
(MRAM). In addition, the computer-readable medium may be a read-only memory 
(ROM), a programmable read-only memory (PROM), an erasable programmable 

1 0 read-only memory (EPROM), an electrically erasable programmable read-only 
memory (EEPROM), or other type of memory device. 

Although the invention is shown and described with respect to certain 
preferred embodiments, it is obvious that equivalents and modifications will occur to 
others skilled in the art upon the reading and understanding of the specification. 

15 The present invention includes all such equivalents and modifications, and is 
limited only by the scope of the claims. 
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